

# **XMICRO BUS**

**Technical Specifications** 

# **Table of Contents**

| 1. Functional Description                                    |   |
|--------------------------------------------------------------|---|
| 1.1 Features                                                 |   |
| 1.2 Elements of a System                                     | 1 |
| 2. Signalling                                                | 2 |
| 2.1 Signal Lines                                             | 2 |
| 2.1.1 Power Supply Rails (+12V, +5V, +5VSB +3.3V, GND, -12V) |   |
| 2.1.2 Address Lines (A<190>)                                 |   |
| 2.1.3 Data Lines (D<70>)                                     |   |
| 2.1.4 Read Strobe (RD)                                       |   |
| 2.1.5 Write Strobe (WR)                                      |   |
| 2.1.6 I/O Select (IOSEL)                                     |   |
| 2.1.7 Card Select X (CSX)                                    |   |
| 2.1.8 Main Memory Inhibit (INH)                              |   |
| 2.1.9 Wait (WAIT)                                            |   |
| 2.1.10 Reset (RST)                                           |   |
| 2.1.11 Bus Request (BRQ)                                     |   |
| 2.1.12 Bus Acknowledge (ACK)                                 |   |
| 2.1.13 Halt (HALT)                                           |   |
| 2.1.13 Halt (HALT)                                           |   |
| 2.1.15 Interrupt Request X (IRQX)                            |   |
| 2.1.15 Interrupt Request \ (IRQ\)                            |   |
| 2.1.17 Interrupt (INT)                                       |   |
| 2.1.18 Non-maskable Interrupt (NMI)                          |   |
|                                                              |   |
| 2.1.19 System Clock (CLK)                                    |   |
| 2.1.20 Unused Pins (NC)                                      |   |
| 2.2 IOSEL                                                    |   |
| 2.3 Bus Arbitration                                          |   |
| 3. System Functionality                                      |   |
| 3.1 Address Spaces                                           |   |
| 3.1.1 Memory                                                 |   |
| 3.1.2 I/O                                                    |   |
| 3.2 Direct Memory Access                                     |   |
| 3.3 Interrupts                                               |   |
| 3.4 Reserved Addresses                                       |   |
| 3.4.1 Card IDs                                               |   |
| 4. Electrical Specifications                                 |   |
| 4.1 Power Supply Characteristics                             |   |
| 4.1.1 Main Power Supply                                      |   |
| 4.1.2 Supplemental Power Supplies                            | 6 |
| 4.2 Signal Characteristics                                   |   |
| 4.3 Connectors                                               |   |
| 4.3.1 Backplane Interconnects                                | 7 |
| 4.3.2 Supplemental Power                                     |   |
| 4.4 Grounding                                                |   |
| 4.4.1 Signal Ground                                          | 8 |
| 4.4.2 Chassis Ground                                         | 8 |
| 5. Physical Specifications                                   | 9 |
| 5.1 Cards                                                    |   |
| 5.2 Backplanes                                               |   |

# **Index of Tables**

| Table 1: Signal Sources                       | 4  |
|-----------------------------------------------|----|
| Table 1: Signal Sources                       | 6  |
| Table 3: Backplane Interconnect Pinout        | 7  |
| Table 4: Supplemental Power Connector Pinout  |    |
| Index of Illustrations                        |    |
| Illustration 1: Card Physical Dimensions      | 11 |
| Illustration 2: Backplane Physical Dimensions | 13 |
|                                               |    |

## 1. Functional Description

### 1.1 Features

- CPU Architecture Independence
- 8-bit Data Field Width
- 1 Megabyte Memory Address Range
- Separate I/O Address Range
- Asynchronous Data Transfer
- Multiple Masters
- Automatic Position-Based Resource Allocation
- Hardware Self-Discovery and Configuration
- Main Memory Inhibit Signal
- ATX Power Supply Compatibility
- Standard 62-pin Card Edge Connector
- Fully Open-source

### 1.2 Elements of a System

An XMICRO system consists of the following elements:

- Backplane
- Primary Master
- · Secondary Masters
- Slaves

An XMICRO *Backplane* is the basis of any system. In its simplest form, the backplane handles power and signal distribution, and card-specific signal routing. Typically it should also include an I/O address decoder, and a power-on reset circuit. More complex implementations may add significantly more functionality, including peripherals or an onboard CPU. When a primary master is built into a backplane, it should be referred to as a motherboard.

A *Primary Master* is a card or motherboard which acts as the default system controller. Typically this will be the main "CPU" card. In the context of this document, the "system controller" is the device driving the A<19..0>,  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ , and  $\overline{\text{FETCH}}$  signals. Primary masters must default to this operation unless the bus is requested by another device. Only primary masters handle interrupt signals and bus requests.

A *Secondary Master* is a card with the ability to act as a temporary system controller. This is generally used for DMA operations by the secondary master, independent of the primary master.

A *Slave* is a card with no ability to control the system. Slaves are only capable of reading/writing data under the command of a master.

Note: The master/slave designation is somewhat loose and is used only as a broad classification of the functionality of a device. It may be used to refer to either a discrete subsystem or a card as a whole.

# 2. Signalling

### 2.1 Signal Lines

### 2.1.1 Power Supply Rails (+12V, +5V, +5VSB +3.3V, GND, -12V)

These lines supply power to the bus. Current capacity is defined by the individual backplane's specifications, as well as Section 4.1. If more current is required, an external power connection should be added to the card (See Section 4.1.2). Voltage tolerances match the ATX standard. It is recommended that a standard ATX power supply be used.

### 2.1.2 Address Lines (A<19..0>)

Twenty unidirectional lines driven by the master to specify a memory or I/O location.

### 2.1.3 Data Lines (D<7..0>)

Eight bi-directional lines which carry information between master and slave devices.

### 2.1.4 Read Strobe ( $\overline{RD}$ )

Asserted by the master to indicate that the addressed slave device may place data on the data lines.

### 2.1.5 Write Strobe (WR)

Asserted by the master to indicate that it has placed data on the data lines.

### 2.1.6 I/O Select (IOSEL)

Asserted by the master to access the backplane's card I/O space. When asserted, A<11..8> determine which backplane slot is being addressed.

### 2.1.7 Card Select X (CSX)

This slot-specific signal is driven by the backplane to indicate that the current address is within the range of the slot's allocated address space. While this signal is asserted, A<19..8> may be ignored by the card because their state is known. Note: this is a discreet signal for each card slot, provided by the backplane.

### 2.1.8 Main Memory Inhibit (INH)

This slot-independent line is used to inhibit general-purpose main memory. When  $\overline{\text{INH}}$  is asserted, main memory must be prevented from reading or writing data, or driving the bus. This precludes the need for special hardware configuration when using devices requiring additional address space.

### 2.1.9 Wait (WAIT)

This open-collector line is asserted by a slave device to indicate that a data transaction is not yet ready to be completed. If  $\overline{\text{WAIT}}$  is asserted concurrently with  $\overline{\text{RD}}$  or  $\overline{\text{WR}}$ , the master must hold all Group A signals in their current state until after  $\overline{\text{WAIT}}$  is deasserted.

### 2.1.10 Reset (RST)

This open-collector signal resets the system into a known state. During the power-on sequence, this signal should be asserted by the backplane until at least 250ms after all power supply rails have stabilized.

### 2.1.11 Bus Request (BRQ)

This slot-independent line is driven by a secondary master to request control of the bus. When the primary master is ready to release control of the bus, it will assert ACK.

### 2.1.12 Bus Acknowledge (ACK)

This signal is held low by the primary master to indicate that it has released the bus for control by a secondary master. The secondary master may only control the bus while this signal is asserted.

### 2.1.13 Halt (HALT)

This status line is asserted by the primary master to indicate to that it is in a halted state and waiting for an interrupt. Not to be confused with  $\overline{\text{WAIT}}$ .

### 2.1.14 Instruction Fetch (FETCH)

This signal is asserted by the primary master when the current data transfer operation is an instruction fetch.

### 2.1.15 Interrupt Request X (IRQX)

This slot-specific line is driven by a card to indicate that it requires the primary master's attention. It is routed to the appropriate input by the backplane. This allows for interrupt vectoring and prioritization based on card position. This is a level-triggered interrupt signal.

### 2.1.16 Interrupt Request (IRQ<7..0>)

These eight lines are driven by cards 7-0 through the IRQX signal. They are used by the primary master for interrupt prioritization and vectoring. Under no circumstances are these lines to be driven directly by a card.

### 2.1.17 Interrupt (INT)

This open-collector signal is used for special purposes where it is necessary to bypass a primary master's onboard interrupt handling circuitry. Typically this is only used to expand interrupt capabilities on backplanes with more than eight slots. Primary masters must accept this signal, either by including it in their interrupt handling scheme or combining it with the CPU's raw interrupt input. This is a level-triggered interrupt signal.

### 2.1.18 Non-maskable Interrupt (NMI)

Open-collector edge-triggered interrupt signal. Its use is unusual, so it is recommended that this signal be optional on any card using it. NMI should only be used for special signals requiring the immediate attention of the primary master, such as memory errors, power failure, or video timing. When possible, primary masters should give this signal an immediate priority override of in-progress interrupts and DMA transfers.

#### 2.1.19 System Clock (CLK)

This signal is the main system clock. Care should be taken to ensure it is a clean square wave. Its frequency and duty cycle are undefined. The primary master should typically provide this signal, however it may optionally be provided by another card such as a video card. It is recommended that primary masters do not strictly require externally generated clock signals to function.

#### 2.1.20 Unused Pins (NC)

These pins are not currently used and their use is reserved for future revisions of this specification. These should be individually connected and terminated on the backplane similarly to other signals.

Table 1: Signal Sources

| Group                  | Signal          | Driver                                                | Receiver                                              |
|------------------------|-----------------|-------------------------------------------------------|-------------------------------------------------------|
|                        | A<190>          | Master                                                | Any                                                   |
|                        | D<70>           | Master ( $\overline{WR}$ ), Slave ( $\overline{RD}$ ) | Slave ( $\overline{WR}$ ), Master ( $\overline{RD}$ ) |
| Α                      | RD              | Master                                                | Any                                                   |
| Information            | $\overline{WR}$ | Master                                                | Any                                                   |
|                        | IOSEL           | Master                                                | Backplane, Memory Systems                             |
|                        | CSX             | Backplane                                             | Cards                                                 |
|                        | ĪNH             | Any                                                   | Memory Systems                                        |
| В                      | WAIT            | Slave                                                 | Master                                                |
| Control                | RST             | Any                                                   | Any                                                   |
|                        | BRQ             | Secondary Master                                      | Primary Master                                        |
| •                      | ACK             | Master                                                | Secondary Master                                      |
| <b>C</b> —<br>Status — | HALT            | Master                                                | Any                                                   |
| Sialus                 | FETCH           | Master                                                | Any                                                   |
|                        | ĪRQX            | Any                                                   | Primary Master                                        |
| D                      | ĪRQ<70>         | Backplane                                             | Primary Master                                        |
| Interrupt              | ĪNT             | Backplane                                             | Primary Master                                        |
|                        | NMI             | Any                                                   | Primary Master                                        |
| E                      | CLK             | Master (Typ.)                                         | Any                                                   |
| Utility                | NC              | None                                                  | None                                                  |

### 2.2 Address Space Selection

See section 3.1 for more information on address spaces.

IOSEL is controlled by the master to indicate which address space is being requested. It is effectively an additional address line. Primary masters must be capable of addressing a minimum of 8 slots.

When  $\overline{\text{IOSEL}}$  is asserted, backplanes must determine which slot is being addressed, and assert the  $\overline{\text{CSX}}$  signal for that slot.

### 2.3 Bus Arbitration

In the system's default state, a primary master has full control of the system bus. By asserting the  $\overline{BRQ}$  line, a secondary master may request to temporarily take over control of some of the bus signals in order to directly access memory. When  $\overline{BRQ}$  is asserted, the primary master gracefully hands over control of the

The  $\overline{ACK}$  signal indicates that the primary master has placed its  $\overline{ACK}$  signals in a high-impedance state. These signals may be driven by a secondary master only while  $\overline{ACK}$  is asserted.

In order to prevent bus contention, secondary masters should wait for a command from the primary master before initiating a bus request, and must not initiate a bus request until the  $\overline{BRQ}$  signal is no longer asserted.

# 3. System Functionality

### 3.1 Address Spaces

The system is divided into two discrete address spaces – "memory" and "I/O".

In the default state,  $\overline{\mathsf{IOSEL}}$  is deasserted, the memory address space is selected and read/write operations apply to memory devices.

When the IOSEL signal is asserted, the I/O memory space is selected and read/write operations apply to I/O devices.

### **3.1.1** Memory

Memory address space layout is defined by the primary master. There are two types of memory that can be added to a system.

- 1) "Main Memory" is memory that is accessable when  $\overline{\text{INH}}$  is deasserted. It is recommended that only one device manages main memory in a system.
- "Override Memory" asserts the INH signal to disable main memory devices. In this way specialized
  memory devices may be added to a system without the need to reconfigure the main memory system.

#### 3.1.2 I/O

Each card slot on a backplane is assigned 256 bytes of I/O address space, beginning at I/O address \$00000. For example, slot 0 addresses are located from \$00000-\$000FF, slot 1 from \$00100-\$001FF, etc. In this way, the third nybble of the address corresponds to the physical slot number being addressed. Typically no more than 16 slots will exist in a system, so I/O addresses are shortened to three nybbles and the upper address byte is ignored.

I/O addresses are typically written in the format \$X00-\$XFF to indicate that the slot address is variable.

## 3.2 Direct Memory Access

Placeholder text

# 3.3 Interrupts

Placeholder text

- 3.3.1 Vectored
- 3.3.2 Non-vectored
- 3.3.3 NMI

### 3.4 Reserved Addresses

Addresses \$XF9-\$XFF are reserved for special bus

#### 3.4.1 Card IDs

Placeholder text

# 4. Electrical Specifications

### 4.1 Power Supply Characteristics

### 4.1.1 Main Power Supply

- A backplane must supply cards with the following voltages: +12V, +5V, +5VSB, GND, -12V.
- Specifications of the power supply are to match the ATX standard.
- The use of an ATX power supply is recommended.

### 4.1.2 Supplemental Power Supplies

Cards may use an additional connector to supplement the +12V, +5V, and GND rails. Where such a connector is used, the following requirements apply:

- All supplemental power rails must match the potential of the bus rails such that no significant current is drawn by conflicting supplies.
- Supplemental power must be delivered using connectors as specified in section 4.3.2.

### 4.2 Signal Characteristics

- A receiver must recognize a voltage of  $\leq 0.8$ V as a logic 0, and a voltage of  $\geq 2.0$ V as a logic 1.
- The minimum sink current capability of any driver on any line must be 24mA at 0.5V. Further, it is recommended that drivers with minimum source capability of 24mA at 2.4V be used.
- Schmitt-trigger inputs must be used for all open-collector signals

Table 2: Bus Driver Output Topologies

| Signal  | Output Device  |
|---------|----------------|
| A<190>  | Tri-state      |
| D<70>   | Tri-state      |
| RD      | Tri-state      |
| WR      | Tri-state      |
| IOSEL   | Tri-state      |
| CSX     | Push-pull      |
| ACK     | Push-pull      |
| HALT    | Push-pull      |
| FETCH   | Push-pull      |
| CLK     | Push-pull      |
| ĪNH     | Open-collector |
| WAIT    | Open-collector |
| RST     | Open-collector |
| BRQ     | Open-collector |
| ĪRQX    | Open-collector |
| ĪRQ<70> | Open-collector |
| ĪNT     | Open-collector |
| NMI     | Open-collector |

### 4.3 Connectors

### 4.3.1 Backplane Interconnects

Backplanes must be fitted with TE Connectivity 7-5530843-0 or equivalent connectors. Each of these connectors is considered a discrete slot.

Cards must be fitted with card-edges compatible with the specified backplane connectors and conforming to physical specifications outlined in section *5.1*. The average current on any backplane connector pin must not exceed 2A.

The recommended maximum current on backplane connectors is 1A for supply pins and 100mA for all other pins.

No bus signal may be delivered between any two devices except by these backplane interconnects.

Table 3: Backplane Interconnect Pinout

| Pin | Signal | Pin | Signal |
|-----|--------|-----|--------|
| 1   | +12V   | 2   | +3.3V  |
| 3   | GND    | 4   | GND    |
| 5   | +5V    | 6   | +5V    |
| 7   | -12V   | 8   | +5VSB  |
| 9   | CSX    | 10  | NC     |
| 11  | NC     | 12  | BRQ    |
| 13  | INH    | 14  | RST    |
| 15  | CLK    | 16  | IOSEL  |
| 17  | HALT   | 18  | WAIT   |
| 19  | FETCH  | 20  | ACK    |
| 21  | RD     | 22  | WR     |
| 23  | A0     | 24  | A1     |
| 25  | A2     | 26  | A3     |
| 27  | A4     | 28  | A5     |
| 29  | A6     | 30  | A7     |
| 31  | A8     | 32  | A9     |
| 33  | A10    | 34  | A11    |
| 35  | A12    | 36  | A13    |
| 37  | A14    | 38  | A15    |
| 39  | A16    | 40  | A17    |
| 41  | A18    | 42  | A19    |
| 43  | D0     | 44  | D1     |
| 45  | D2     | 46  | D3     |
| 47  | D4     | 48  | D5     |
| 49  | D6     | 50  | D7     |
| 51  | INT    | 52  | IRQX   |
| 53  | IRQ0   | 54  | IRQ1   |
| 55  | IRQ2   | 56  | IRQ3   |
| 57  | IRQ4   | 58  | IRQ5   |
| 59  | IRQ6   | 60  | IRQ7   |
| 61  | NMI    | 62  | GND    |

### 4.3.2 Supplemental Power

TE Connectivity 174804-1 (Male) or equivalent installed on cards. Pinout and current limits match the ATX standard for peripheral connectors.

Table 4: Supplemental Power Connector Pinout

| Pin | Signal |
|-----|--------|
| 1   | +12V   |
| 2   | GND    |
| 3   | GND    |
| 4   | +5V    |

## 4.4 Grounding

### 4.4.1 Signal Ground

The GND supply rail serves as the 0V reference and return path for all bus signals.

#### 4.4.2 Chassis Ground

A separate chassis ground must be maintained for conductive chassis members. The purpose of the chassis ground is to provide a safe return path for ESD, and to avoid stray ground paths between cards which could result in unpredictable operation.

Where mechanical mounting holes in cards can be used to make an electrical connection to chassis components or other cards, those holes must be insulated from the signal ground. They are not required to be tied together on the PCB.

Where connectors have a separate shield conductor that is not used as a signal ground, the shield should be tied to chassis ground.

Chassis ground should be tied to the signal ground at the backplane.

# 5. Physical Specifications

### 5.1 Cards

- A card's dimensions must not exceed the overall dimensions shown in Illustration 1.
- Card edge connectors must match the dimensions shown in *Illustration* 1.
- Pin 1 of the edge connector must be indicated on the card.
- Card edges should be gold-plated for reliability. HASL or similar surface finishes are discouraged.
- Card edges should be chamfered for easier insertion.
- The use of standard "full-size" and "half-size" card form-factors shown in *Illustration 1* is strongly encouraged.
- Standard card mounting holes should be isolated from the backplane's GND pins and treated as a discreet chassis ground if conductive.
- I/O connectors may only be placed on the rear edge. Other edges require 0.05" component clearence

### 5.2 Backplanes

- Card slots must have a minimum 0.75" center-to-center spacing.
- Pin 1 must be indicated on at least one slot.
- Each slot number must be indicated on the PCB
- Maximum component height under cards may not exceed the edge connectors
- All backplane slots must be capable of receiving full-dimension cards



Illustration 1: Card Physical Dimensions

